User guide previous pagenext page

1.3: Sizes and units Go back up one level

In the previous section we noted that when using layouts you never need to set the position or size of a user-interface component yourself - the layouts take care of it. So how do you control the sizes of the components?

Each layout that arranges multiple items within its drawing area has a sizing property: for horizontal boxes this is Widths and for vertical boxes Heights; for grids we have both Widths and Heights. These all obey the same convention:

  1. Positive numbers indicate sizes in pixels (similar to "pixel" units)
  2. Negative numbers indicate a weighting for variable sizing (similar to "normalized" units)

By default all sizes are set to -1 (variable size with unit weighting).

Let's take a simple example:

f = figure();
layout = uix.HBox( 'Parent', f );
uicontrol( 'String', 'Button 1', 'Parent', layout );
uicontrol( 'String', 'Button 2', 'Parent', layout );
uicontrol( 'String', 'Button 3', 'Parent', layout );

We can set the middle element to be twice as wide as the others (but still variable width) by setting its weight to -2 with the others at -1:

layout.Widths = [-1 -2 -1]

Alternatively we might want the first element to have a fixed width of 100 pixels with the others filling any remaining space equally:

layout.Widths = [100 -1 -1]

This ability to mix fixed and variable sized elements is crucial in interface design. It really comes into its own when building a hierarchy of layouts, described next.



   1.3.1: Minimum sizes Go back up one level

Many of the multi-element layouts also provide a MinimumWidths or MinimumHeights property to prevent an element becoming too small. This is measured in pixels and defaults to one pixel. Take care to ensure that the available space is at least the sum of the minimum sizes, plus any padding and spacing.


© 2016 The MathWorks Ltd Terms of Use Patents Trademarks